Request এবং Response Handling

Web Development - অ্যাজাক্স (Ajax) - XMLHttpRequest Object এর ব্যবহার (Using the XMLHttpRequest Object) |
1
1

Ajax এর মাধ্যমে Request এবং Response Handling হলো ওয়েব সার্ভার এবং ক্লায়েন্ট (ব্রাউজার) এর মধ্যে ডেটা আদান-প্রদানের একটি প্রক্রিয়া। Ajax রিকোয়েস্টের মাধ্যমে সার্ভারে তথ্য পাঠানো হয় এবং সার্ভার থেকে প্রাপ্ত রেসপন্স ডেটা প্রসেস করা হয়। XMLHttpRequest অবজেক্ট ব্যবহার করে এই প্রক্রিয়াটি সম্পন্ন করা হয়। নিচে Request এবং Response Handling এর বিস্তারিত আলোচনা এবং উদাহরণ তুলে ধরা হলো।

Request Handling:

Request Handling হলো সেই প্রক্রিয়া, যেখানে একটি Ajax রিকোয়েস্ট সার্ভারে পাঠানো হয় এবং এই রিকোয়েস্টটি কীভাবে সেটআপ এবং পরিচালনা করা হয়।

ধাপগুলো:

১. XMLHttpRequest অবজেক্ট তৈরি করা:

  • JavaScript এর মাধ্যমে একটি XMLHttpRequest অবজেক্ট তৈরি করা হয়, যা Ajax রিকোয়েস্ট পরিচালনা করবে।
var xhr = new XMLHttpRequest();

২. রিকোয়েস্ট ওপেন করা:

  • open() মেথড ব্যবহার করে HTTP মেথড (যেমন GET বা POST), সার্ভারের URL এবং অ্যাসিনক্রোনাস বা সিঙ্ক্রোনাস সেট করা হয়।
xhr.open("GET", "https://jsonplaceholder.typicode.com/posts/1", true);

৩. রিকোয়েস্ট হেডার সেট করা (ঐচ্ছিক):

  • যদি POST রিকোয়েস্ট হয়, তবে setRequestHeader() মেথড ব্যবহার করে কনটেন্ট টাইপ বা অন্যান্য হেডার সেট করা হয়।
xhr.setRequestHeader("Content-Type", "application/json");

৪. রিকোয়েস্ট পাঠানো:

  • send() মেথড ব্যবহার করে রিকোয়েস্টটি সার্ভারে পাঠানো হয়।
xhr.send();
  • POST রিকোয়েস্টের ক্ষেত্রে ডেটা প্যারামিটার হিসেবে send() এ পাঠানো হয়।

Response Handling:

Response Handling হলো সেই প্রক্রিয়া, যেখানে সার্ভার থেকে প্রাপ্ত রেসপন্স ডেটা প্রসেস করা হয় এবং UI বা HTML DOM আপডেট করা হয়।

ধাপগুলো:

১. onreadystatechange ইভেন্ট হ্যান্ডলার সেট করা:

  • রিকোয়েস্টের অবস্থা পরিবর্তন হলে onreadystatechange ইভেন্ট হ্যান্ডলার ট্রিগার হয়।
xhr.onreadystatechange = function() {
   if (xhr.readyState === 4) {
       // রেসপন্স প্রসেস করা
   }
};
  • readyState এবং status ব্যবহার করে চেক করা হয় যে রিকোয়েস্ট সম্পূর্ণ এবং সফল হয়েছে কিনা।
    • readyState === 4 নির্দেশ করে রিকোয়েস্ট সম্পূর্ণ।
    • status === 200 নির্দেশ করে রিকোয়েস্ট সফল।

২. রেসপন্স ডেটা প্রসেস করা:

  • যদি রিকোয়েস্ট সফল হয়, তবে responseText বা responseXML ব্যবহার করে ডেটা রিসিভ করা হয় এবং প্রসেস করা হয়।
if (xhr.readyState === 4 && xhr.status === 200) {
   var data = JSON.parse(xhr.responseText);
   console.log(data);
}
  • responseText ব্যবহার করে প্লেইন টেক্সট বা JSON ডেটা রিসিভ করা যায়।
  • যদি XML ফরম্যাটের ডেটা আসে, তবে responseXML ব্যবহার করা হয়।

৩. HTML DOM আপডেট করা:

  • প্রাপ্ত ডেটা ব্যবহার করে HTML DOM এ পরিবর্তন আনা হয়, যেমন নতুন কন্টেন্ট যোগ করা বা বিদ্যমান কন্টেন্ট আপডেট করা।
document.getElementById("data-container").innerHTML = `
   <h2>${data.title}</h2>
   <p>${data.body}</p>
`;

এরর হ্যান্ডলিং:

  • যদি রিকোয়েস্ট ব্যর্থ হয় (যেমন status ২০০ না হয়), তবে একটি এরর মেসেজ বা লজিক্যাল এক্সেপশন হ্যান্ডল করা হয়।
if (xhr.readyState === 4 && xhr.status !== 200) {
   console.error("Request failed with status: " + xhr.status);
}

সম্পূর্ণ উদাহরণ: Request এবং Response Handling

function fetchData() {
    // XMLHttpRequest অবজেক্ট তৈরি করা
    var xhr = new XMLHttpRequest();
    
    // রিকোয়েস্ট ওপেন করা (GET মেথড, URL এবং অ্যাসিনক)
    xhr.open("GET", "https://jsonplaceholder.typicode.com/posts/1", true);
    
    // রেসপন্স হ্যান্ডলিং সেট করা
    xhr.onreadystatechange = function() {
        if (xhr.readyState === 4) { // রিকোয়েস্ট সম্পূর্ণ
            if (xhr.status === 200) { // রিকোয়েস্ট সফল
                var data = JSON.parse(xhr.responseText); // JSON ডেটা প্রসেস করা
                document.getElementById("data-container").innerHTML = `
                    <h2>${data.title}</h2>
                    <p>${data.body}</p>
                `;
            } else {
                // এরর হ্যান্ডলিং
                document.getElementById("data-container").innerHTML = "Error loading data!";
            }
        }
    };
    
    // রিকোয়েস্ট পাঠানো
    xhr.send();
}

এই উদাহরণে কী হচ্ছে:

  1. রিকোয়েস্ট পাঠানো:
    • fetchData() ফাংশন কল করলে একটি GET রিকোয়েস্ট তৈরি হয় এবং https://jsonplaceholder.typicode.com/posts/1 থেকে ডেটা ফেচ করা হয়।
  2. রেসপন্স হ্যান্ডলিং:
    • রিকোয়েস্ট সফল হলে (status 200), JSON ডেটা প্রসেস করা হয় এবং HTML পেজে ইনজেক্ট করা হয়।
    • যদি কোনো এরর হয়, তবে একটি এরর মেসেজ দেখানো হয়।

সারসংক্ষেপ:

  • Request Handling: Ajax রিকোয়েস্ট সেটআপ ও সার্ভারে পাঠানোর প্রক্রিয়া।
  • Response Handling: সার্ভার থেকে প্রাপ্ত ডেটা প্রসেস ও HTML আপডেট করার প্রক্রিয়া।

এই ধাপগুলোর মাধ্যমে Ajax এর Request এবং Response Handling সম্পন্ন করা হয়, যা ওয়েব পেজকে ডায়নামিক এবং ইন্টারেক্টিভ করে তোলে।

Promotion